Reactã®experimental_TracingMarkerãæ·±ãæãäžãããã®ããã©ãŒãã³ã¹ãžã®åœ±é¿ãšãã¬ãŒã¹åŠçã®ãªãŒããŒããããåæããŸãããã®åŒ·åãªããŒã«ã䜿çšããŠReactã¢ããªã±ãŒã·ã§ã³ãæé©åããæ¹æ³ãåŠã³ãŸãããã
React experimental_TracingMarkerã®ããã©ãŒãã³ã¹ãžã®åœ±é¿ïŒãã¬ãŒã¹åŠçã®ãªãŒããŒããã
React 18ã§å°å
¥ãããReactã®experimental_TracingMarker APIã¯ãReactã¢ããªã±ãŒã·ã§ã³å
ã®ããã©ãŒãã³ã¹ããã«ããã¯ããã¬ãŒã¹ããã³ãããã¡ã€ãªã³ã°ããããã®åŒ·åãªã¡ã«ããºã ãæäŸããŸããããã«ãããéçºè
ã¯ã³ã³ããŒãã³ããã©ã®ããã«ã¬ã³ããªã³ã°ãããçžäºäœçšãããã«ã€ããŠããæ·±ãæŽå¯ãåŸãããšãã§ãããã广çãªæé©åæŠç¥ã«ã€ãªãããŸããããããä»ã®åŒ·åãªããŒã«ãšåæ§ã«ãexperimental_TracingMarkerèªäœãããããæœåšçãªããã©ãŒãã³ã¹ã®ãªãŒããŒããããçè§£ããããšãéèŠã§ãããã®èšäºã§ã¯ããã®APIã䜿çšããã¡ãªãããšãã¡ãªãããæ¢ãããã¬ãŒã¹åŠçã®ãªãŒããŒãããã«çŠç¹ãåœãŠããã®åœ±é¿ã軜æžããããã®å®è·µçãªã¬ã€ãã³ã¹ãæäŸããŸãã
experimental_TracingMarkerãçè§£ãã
experimental_TracingMarker APIã¯ãã³ãŒãã®ç¹å®ã»ã¯ã·ã§ã³ã«ã©ãã«ãä»ããŠããŒã¯ããæ¹æ³ãæäŸããReact DevToolsã®ãããã¡ã€ã©ã§ãããã®ã»ã¯ã·ã§ã³ã®å®è¡ã«è²»ããããæéã远跡ã§ããããã«ããŸããããã¯ãé
ããŸãã¯äºæããªãã¬ã³ããªã³ã°ãã¿ãŒã³ããåã
ã®ã³ã³ããŒãã³ããã€ã³ã¿ã©ã¯ã·ã§ã³å
ã®ããã©ãŒãã³ã¹åé¡ãç¹å®ããã®ã«ç¹ã«åœ¹ç«ã¡ãŸããã³ãŒãå®è¡ãã¹ã«ãã³ãããªã¹ãã远å ãããããªãã®ã§ãæé ãé¡ã£ãŠããã©ãŒãã³ã¹ã®ããã«ããã¯ãããæ£ç¢ºã«ç¹å®ã§ããŸãã
åºæ¬çãªã³ã³ã»ããã¯ãã³ãŒãã®ã»ã¯ã·ã§ã³ãexperimental_TracingMarkerã³ã³ããŒãã³ããŸãã¯é¢æ°ã§ã©ããããããšã§ããäŸïŒ
import { experimental_TracingMarker } from 'react';
function MyComponent() {
return (
<experimental_TracingMarker id="expensiveOperation" passive={true}>
{/* Code that performs an expensive operation */}
</experimental_TracingMarker>
);
}
ããã§ãIDããexpensiveOperationãã®experimental_TracingMarkerå
ã®ã³ãŒãã¯ããããã¡ã€ãªã³ã°äžã«è¿œè·¡ãããŸããpassive propã¯ããã¬ãŒã¹ãã¢ã¯ãã£ããããã·ãããæ±ºå®ããŸããããã·ããã¬ãŒã¹ã¯ãªãŒããŒããããæå°éã«æãããããæ¬çªç°å¢ã«é©ããŠããŸããããã©ã«ãã§ã¯passiveã¯falseã§ããpassiveãfalseã®å ŽåãReactã¯æäœãåæçã«ãã¬ãŒã¹ããŸããããã¯ããæ£ç¢ºã§ããããªãŒããŒããããé«ããªããŸãã
TracingMarkerã䜿çšããã¡ãªãã
- æ£ç¢ºãªããã©ãŒãã³ã¹æž¬å®ïŒ ã¢ããªã±ãŒã·ã§ã³ã®ã©ã®éšåããããã¡ã€ãªã³ã°ãããã现ããå¶åŸ¡ã§ããæžå¿µãããç¹å®ã®é åã«çŠç¹ãåœãŠã調æ»ãå¯èœã§ããå€§èŠæš¡ã§äžè¬çãªãããã¡ã€ã«ãèŠã代ããã«ãç¹å®ã®ã³ã³ããŒãã³ããã€ã³ã¿ã©ã¯ã·ã§ã³ã«çµã蟌ãããšãã§ããŸãã
- ã¬ã³ããªã³ã°ããã«ããã¯ã®ç¹å®ïŒ äžå¿ èŠã«åã¬ã³ããªã³ã°ãããŠããããŸãã¯ã¬ã³ããªã³ã°ã«éå°ãªæéãããã£ãŠããã³ã³ããŒãã³ããç¹å®ããã®ã«åœ¹ç«ã¡ãŸããããã«ãããã¡ã¢åãã³ãŒãåå²ãªã©ã®æé©åæè¡ãé©çšããŠããã©ãŒãã³ã¹ãåäžãããããšãã§ããŸãã
- ãããã°ã¯ãŒã¯ãããŒã®æ¹åïŒ React DevToolsã§ã³ã³ããŒãã³ãã®ã¬ã³ããªã³ã°æéãæç¢ºã«èŠèŠåããããšã§ããããã°ããã»ã¹ãå¹çåããŸããããã«ãããããã©ãŒãã³ã¹åé¡ã®æ ¹æ¬åå ãç¹å®ãããããªããŸãã
- è€éãªã€ã³ã¿ã©ã¯ã·ã§ã³ã®çè§£ïŒ ã¢ããªã±ãŒã·ã§ã³å ã®è€éãªã€ã³ã¿ã©ã¯ã·ã§ã³ãããŒã¿ãããŒã®ãã¬ãŒã¹ãå¯èœã«ããããŸããŸãªã³ã³ããŒãã³ããã©ã®ããã«çžäºäœçšããå šäœçãªããã©ãŒãã³ã¹ã«è²¢ç®ãããã«ã€ããŠã®è²ŽéãªæŽå¯ãæäŸããŸããäŸãã°ããŠãŒã¶ãŒã¢ã¯ã·ã§ã³ããæçµçãªUIæŽæ°ãŸã§ã®ããŒã¿ãããŒããã¬ãŒã¹ã§ããŸãã
- ç°ãªãå®è£ ã®æ¯èŒïŒ åãæ©èœã®ç°ãªãå®è£ ã®ããã©ãŒãã³ã¹ãæ¯èŒã§ããŸããããã¯ã代æ¿ã®ã¢ã«ãŽãªãºã ãããŒã¿æ§é ãè©äŸ¡ããéã«åœ¹ç«ã¡ãŸãã
ããã©ãŒãã³ã¹ãžã®åœ±é¿ïŒãã¬ãŒã¹åŠçã®ãªãŒããŒããã
experimental_TracingMarkerã¯ããã©ãŒãã³ã¹åæã«å€§ããªã¡ãªããããããããŸããããããããããããã©ãŒãã³ã¹ã®ãªãŒããŒããããèªèããããšãäžå¯æ¬ ã§ããããã©ãŒãã³ã¹ããŒã¿ããã¬ãŒã¹ãåéãåŠçããè¡çºã¯CPUãµã€ã¯ã«ãšã¡ã¢ãªãæ¶è²»ããç¹ã«æ¬çªç°å¢ãäœã¹ããã¯ã®ããã€ã¹ã§å®è¡ããå Žåãã¢ããªã±ãŒã·ã§ã³å
šäœã®å¿çæ§ã«åœ±é¿ãäžããå¯èœæ§ããããŸãã
ãªãŒããŒãããã®åå
- ã€ã³ã¹ãã«ã¡ã³ããŒã·ã§ã³ã®ãªãŒããŒãããïŒ å
experimental_TracingMarkerã¯ãã¬ã³ããªã³ã°äžã«å®è¡ããå¿ èŠããã远å ã®ã³ãŒããã¢ããªã±ãŒã·ã§ã³ã«è¿œå ããŸãããã®ã€ã³ã¹ãã«ã¡ã³ããŒã·ã§ã³ã³ãŒãã¯ãã¿ã€ããŒã®éå§ãšåæ¢ãããã©ãŒãã³ã¹ã¡ããªã¯ã¹ã®åéãReact DevToolsãžã®ããŒã¿å ±åãæ åœããŸããpassiveã¢ãŒãã§ãã£ãŠããããçšåºŠã®ã€ã³ã¹ãã«ã¡ã³ããŒã·ã§ã³ã®ãªãŒããŒãããã¯ååšããŸãã - ããŒã¿åéãšã¹ãã¬ãŒãžïŒ ãã¬ãŒã¹ãããããŒã¿ã¯åéããŠä¿åããå¿ èŠããããããã¯ã¡ã¢ãªãæ¶è²»ããã¬ããŒãžã³ã¬ã¯ã·ã§ã³ã«ããäžæåæ¢ãåŒãèµ·ããå¯èœæ§ããããŸãã远å ãããã¬ãŒã¹ãå€ããã°å€ãã»ã©ããŸãå®è¡æéãé·ããã°é·ãã»ã©ãåéããå¿ èŠã®ããããŒã¿éãå¢ããŸãã
- åŠçãšå ±åïŒ åéãããããŒã¿ã¯åŠçãããReact DevToolsã«å ±åãããå¿ èŠããããããã¯ç¹ã«å€§èŠæš¡ã§è€éãªã¢ããªã±ãŒã·ã§ã³ãæ±ãå Žåã«ã远å ã®ãªãŒããŒããããçããããå¯èœæ§ããããŸããããã«ã¯ãããŒã¿ã®ãã©ãŒããããšéä¿¡ã«è²»ããããæéãå«ãŸããŸãã
ãªãŒããŒãããã®æž¬å®
experimental_TracingMarkerã®å®éã®ãªãŒããŒãããã¯ã以äžãå«ãããã€ãã®èŠå ã«ãã£ãŠç°ãªããŸãã
- ãã¬ãŒã¹ããŒã«ãŒã®æ°ïŒ ããŒã«ãŒã远å ããã°ããã»ã©ããªãŒããŒãããã¯å€§ãããªããŸãã
- ãã¬ãŒã¹ãããæäœã®æéïŒ å®è¡æéãé·ãæäœã»ã©ãããå€ãã®ãã¬ãŒã¹ããŒã¿ãçæãããŸãã
- ãã¬ãŒã¹ãããæäœã®é »åºŠïŒ é »ç¹ã«å®è¡ãããæäœã¯ãå šäœçãªãªãŒããŒããããžã®å¯äžã倧ãããªããŸãã
- ããã€ã¹ã®èœåïŒ äœã¹ããã¯ã®ããã€ã¹ã¯ããã¬ãŒã¹ã«ããããã©ãŒãã³ã¹ãžã®åœ±é¿ãåãããããªããŸãã
- Reactã®ãã«ãã¢ãŒãïŒ Reactã®éçºãã«ãã¯ã远å ã®ãã§ãã¯ãèŠåãå«ãŸããŠãããããæ¬è³ªçã«ããå€ãã®ãªãŒããŒãããã䌎ããŸãã
ãªãŒããŒããããæ£ç¢ºã«æž¬å®ããããã«ã¯ã代衚çãªã¯ãŒã¯ããŒããšçŸå®äžçã®ãŠãŒã¶ãŒã·ããªãªã䜿çšããŠãexperimental_TracingMarkerãæå¹ã«ããå Žåãšç¡å¹ã«ããå Žåã§ããã©ãŒãã³ã¹ãã¹ããå®è¡ããããšããå§ãããŸããLighthouseãWebPageTestãã«ã¹ã¿ã ãã³ãããŒãã³ã°ã¹ã€ãŒããªã©ã®ããŒã«ã䜿çšããŠãTime to Interactive (TTI)ãFirst Contentful Paint (FCP)ãå
šäœçãªãã¬ãŒã ã¬ãŒããªã©ã®ã¡ããªã¯ã¹ãžã®åœ±é¿ãå®éåã§ããŸãã
äŸïŒãªãŒããŒãããã®å®éå
å€§èŠæš¡ãªã¢ã€ãã ã®ãªã¹ããã¬ã³ããªã³ã°ããè€éãªã³ã³ããŒãã³ãããããšæ³åããŠãã ããããã®ãªã¹ãã®ã¬ã³ããªã³ã°ãããã©ãŒãã³ã¹åé¡ãåŒãèµ·ãããŠãããšçã£ãŠããŸãããªã¹ãã®ã¬ã³ããªã³ã°ããžãã¯ãã©ããããããã«experimental_TracingMarkerã远å ããŸãã
import { experimental_TracingMarker } from 'react';
function MyListComponent({ items }) {
return (
<experimental_TracingMarker id="listRendering" passive={true}>
<ul>
{items.map(item => (
<li key={item.id}>{item.name}</li>
))}
</ul>
</experimental_TracingMarker>
);
}
次ã«ã1000åã®ã¢ã€ãã ã®ãªã¹ãã§ããã©ãŒãã³ã¹ãã¹ããå®è¡ããŸããexperimental_TracingMarkerããªããšãã¬ã³ããªã³ã°ã«ã¯100msããããŸããexperimental_TracingMarkerïŒããã·ãã¢ãŒãïŒã䜿çšãããšãã¬ã³ããªã³ã°ã«ã¯105msããããŸããããã¯5msã®ãªãŒããŒããããã€ãŸãã¬ã³ããªã³ã°æéã5%å¢å ããããšã瀺ããŸãã5msã¯äºçŽ°ã«æãããããããŸããããã¢ããªã±ãŒã·ã§ã³ã«ãã®ãããªããŒã«ãŒã倿°ããå Žåããã¬ã³ããªã³ã°ãé »ç¹ã«å®è¡ãããå Žåã«ã¯èç©ãããå¯èœæ§ããããŸããéããã·ãã¢ãŒãã§ã¯ãå¢å ã¯å€§å¹
ã«é«ããªãå¯èœæ§ããããŸãã
ããã©ãŒãã³ã¹ãžã®åœ±é¿ã軜æžããããã®æŠç¥
幞ããªããšã«ãexperimental_TracingMarkerã«ãã£ãŠçããããã©ãŒãã³ã¹ã®ãªãŒããŒããããæå°éã«æããããã«æ¡çšã§ããæŠç¥ãããã€ããããŸãã
- æ§ããã«äœ¿çšããïŒ ããã©ãŒãã³ã¹ã®åé¡ãçãããé åã§ã®ã¿
experimental_TracingMarkerã䜿çšããŸããã³ãŒãããŒã¹å šäœã«ç¡å·®å¥ã«ããŒã«ãŒã远å ããããšã¯é¿ããŠãã ãããæãéèŠãŸãã¯åé¡ã®ããã³ã³ããŒãã³ããšã€ã³ã¿ã©ã¯ã·ã§ã³ã«çŠç¹ãåœãŠãŸãã - æ¡ä»¶ä»ããã¬ãŒã¹ïŒ éçºäžããããã°ã»ãã·ã§ã³äžãªã©ãå¿ èŠãªå Žåã«ã®ã¿ãã¬ãŒã¹ãæå¹ã«ããŸããç°å¢å€æ°ãæ©èœãã©ã°ã䜿çšããŠããã¬ãŒã¹ãåçã«æå¹ãŸãã¯ç¡å¹ã«ããããšãã§ããŸããäŸïŒ
- ããã·ãã¢ãŒãïŒ æ¬çªç°å¢ã§ã®ãªãŒããŒããããæå°éã«æããããã«
passive={true}propãå©çšããŸããããã·ããã¬ãŒã¹ã¯ããã©ãŒãã³ã¹ãžã®åœ±é¿ã軜æžããŸãããã¢ã¯ãã£ããã¬ãŒã¹ãããè©³çŽ°ãªæ å ±ãåŸãããªãå ŽåããããŸãã - éžæçãã¬ãŒã¹ïŒ ã³ã³ããŒãã³ãå šäœããã¬ãŒã¹ããã®ã§ã¯ãªããåé¡ããããšçãããã³ã³ããŒãã³ãå ã®ç¹å®ã®ã³ãŒãã»ã¯ã·ã§ã³ã®ãã¬ãŒã¹ã«çŠç¹ãåœãŠãŸããããã«ãããåéããã³åŠçãããããŒã¿éãæžããããšãã§ããŸãã
- ãµã³ããªã³ã°ïŒ ãµã³ããªã³ã°æè¡ãå®è£ ããŠãæäœã®ãµãã»ããã®ã¿ããã¬ãŒã¹ããŸããããã¯ããã¹ãŠã®ã€ã³ã¹ã¿ã³ã¹ããã¬ãŒã¹ããã«ã¯ã³ã¹ããé«ãããé«é »åºŠã®æäœã«ç¹ã«åœ¹ç«ã¡ãŸããäŸãã°ã颿°ã®10åã«1åã®åŒã³åºãã®ã¿ããã¬ãŒã¹ããããšãã§ããŸãã
- ãã¬ãŒã¹å¯Ÿè±¡ã³ãŒãã®æé©åïŒ ç®èãªããšã«ã
experimental_TracingMarkerå ã®ã³ãŒããæé©åããããšèªäœãããã¬ãŒã¹ã®ãªãŒããŒããããåæžããããšã«ã€ãªãããŸããã³ãŒãã®å®è¡ãéãã»ã©ããã¬ãŒã¹ããŒã¿ã®åéã«è²»ããæéãçããªããŸãã - æ¬çªç°å¢ã§ã®åé€ïŒ çæ³çã«ã¯ãæ¬çªãã«ããããã¹ãŠã®
experimental_TracingMarkerã³ã³ããŒãã³ããåé€ããŸãããã«ãããŒã«ã䜿çšããŠããã«ãããã»ã¹äžã«ãã¬ãŒã¹ã³ãŒããåé€ããŸããããã«ãããæ¬çªç°å¢ã§ãã¬ãŒã¹ã®ãªãŒããŒããããçºçããªãããšãä¿èšŒãããŸããbabel-plugin-strip-dev-codeã®ãããªããŒã«ã䜿çšããŠãæ¬çªãã«ãã§ã®ãã¬ãŒã¹ããŒã«ãŒã®åé€ãèªååã§ããŸãã - ã³ãŒãåå²ïŒ
experimental_TracingMarkerã䜿çšããã³ãŒãã®èªã¿èŸŒã¿ãé å»¶ãããŸããããã«ãããåæèªã¿èŸŒã¿æéãççž®ã§ããŸãã - ã¡ã¢åïŒ ã¡ã¢åæè¡ïŒäŸïŒReact.memo, useMemoïŒãå®è£ ããŠãã³ã³ããŒãã³ãã®äžèŠãªåã¬ã³ããªã³ã°ãé²ããŸããããã«ããããã¬ãŒã¹ã³ãŒããå®è¡ãããåæ°ãæžå°ããŸãã
const isTracingEnabled = process.env.NODE_ENV === 'development';
function MyComponent() {
return (
<>{
isTracingEnabled ? (
<experimental_TracingMarker id="expensiveOperation" passive={true}>
{/* Code that performs an expensive operation */}
</experimental_TracingMarker>
) : (
{/* Code that performs an expensive operation */}
)}
</>
);
}
ã°ããŒãã«ãªèæ ®äºé ãšãã¹ããã©ã¯ãã£ã¹
experimental_TracingMarkerãã°ããŒãã«ãªæèã§äœ¿çšããå Žåã以äžã®ãã¹ããã©ã¯ãã£ã¹ãèæ
®ããããšãäžå¯æ¬ ã§ãã
- ããã€ã¹ã®å€æ§æ§ïŒ äœã¹ããã¯ã®ã¢ãã€ã«ããã€ã¹ãå«ãããŸããŸãªããã€ã¹ã§ã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹ããã¹ãããããŸããŸãªããã€ã¹èœåãæã€ç°ãªãå°åã®ãŠãŒã¶ãŒã«ãšã£ãŠããã¬ãŒã¹ã®ãªãŒããŒãããããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ã«æªåœ±é¿ãäžããªãããšã確èªããŸããäŸãã°ãçºå±éäžåœã®ãŠãŒã¶ãŒã¯ãå€ããŸãã¯äœã¹ããã¯ã®ããã€ã¹ã䜿çšããå¯èœæ§ãé«ããªããŸãã
- ãããã¯ãŒã¯ç¶æ³ïŒ ãã¬ãŒã¹ããŒã¿ã®å ±åã«å¯Ÿãããããã¯ãŒã¯é å»¶ã®åœ±é¿ãèæ ®ããŸããã€ã³ã¿ãŒãããæ¥ç¶ãé ãå°åã®ãŠãŒã¶ãŒã¯ããã¬ãŒã¹ããŒã¿ãéä¿¡ãããéã«é å»¶ãã¿ã€ã ã¢ãŠããçµéšããå¯èœæ§ããããŸãããããã¯ãŒã¯é å»¶ã®åœ±é¿ãæå°éã«æããããã«ãéä¿¡ãããããŒã¿éãæé©åããŸãã
- ããŒã¿ãã©ã€ãã·ãŒïŒ ãã¬ãŒã¹ããŒã¿ãåéããã³ä¿åããéã«ã¯ãGDPRãªã©ã®ããŒã¿ãã©ã€ãã·ãŒèŠå¶ã«æ³šæããŠãã ããããŠãŒã¶ãŒã®åæãªãã«å人ãç¹å®ã§ããæ å ±ïŒPIIïŒãåéããŠããªãããšã確èªããŸãããŠãŒã¶ãŒã®ãã©ã€ãã·ãŒãä¿è·ããããã«ããã¬ãŒã¹ããŒã¿ãå¿ååãŸãã¯ä»®ååããŸãã
- åœéåïŒi18nïŒïŒ
experimental_TracingMarkerã«äœ¿çšãããIDããç°ãªãèšèªéã§æå³ãããäžè²«ããŠããããšã確èªããŸããç°ãªããã±ãŒã«éã§ã®åæãšãããã°ã容æã«ããããã«ããã¬ãŒã¹ããŒã«ãŒã«äžè²«ããåœåèŠåã䜿çšããŸãã - ã¢ã¯ã»ã·ããªãã£ïŒ React DevToolsã«è¡šç€ºããããã¬ãŒã¹ããŒã¿ã¯ãé害ãæã€ãŠãŒã¶ãŒã«ãã¢ã¯ã»ã¹å¯èœã§ããã¹ãã§ããèŠèŠåããŒã«ã代æ¿ããã¹ãã®èª¬æãšããŒããŒãããã²ãŒã·ã§ã³ãæäŸããããšã確èªããŸãã
- ã¿ã€ã ãŸãŒã³ïŒ ãã¬ãŒã¹ããŒã¿ãåæããéã«ã¯ããŠãŒã¶ãŒã®ç°ãªãã¿ã€ã ãŸãŒã³ã«æ³šæããŠãã ãããæ£ç¢ºãªåæã®ããã«ãã¿ã€ã ã¹ã¿ã³ããäžè²«ããã¿ã€ã ãŸãŒã³ã«å€æããŸãã
çµè«
experimental_TracingMarkerã¯ãReactã¢ããªã±ãŒã·ã§ã³ã«ãããããã©ãŒãã³ã¹åæãšãããã°ã®ããã®è²ŽéãªããŒã«ã§ãããã¬ãŒã¹åŠçã®ãªãŒããŒããããçè§£ãããã®èšäºã§æŠèª¬ããæŠç¥ãå®è£
ããããšã§ããã®APIã广çã«æŽ»çšããŠã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹ãæé©åãããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãžã®åœ±é¿ãæå°éã«æããããšãã§ããŸããæ
éã«äœ¿çšããæ¡ä»¶ä»ãã§æå¹ã«ããåžžã«ãã®åœ±é¿ã枬å®ããŠãã¢ããªã±ãŒã·ã§ã³ã«çŽç²ãªå©çããããããŠããããšã確èªããããšãå¿ããªãã§ãã ããããã¬ãŒã¹æŠç¥ã宿çã«èŠçŽããæŽç·Žãããããšã§ãäžçäžã®ãŠãŒã¶ãŒã®ããã«é«æ§èœã§å¿çæ§ã®é«ãã¢ããªã±ãŒã·ã§ã³ãç¶æããããšãã§ããŸãã
éžæçãã¬ãŒã¹ãæ¡ä»¶ä»ãå®è¡ãããã³æ¬çªç°å¢ã§ã®åé€ã®ååãææ
®æ·±ãé©çšããããšã§ãäžçäžã®éçºè
ã¯experimental_TracingMarkerã®åãæŽ»çšããŠãããéããããå¹ççã§ãããæ¥œããReactã¢ããªã±ãŒã·ã§ã³ãæ§ç¯ã§ããŸãã